﻿#include "header.h"

/*

给定一组非负整数 nums，重新排列每个数的顺序（每个数不可拆分）使之组成一个最大的整数。

注意：输出结果可能非常大，所以你需要返回一个字符串而不是整数。

示例 1：
输入：nums = [10,2]
输出："210"

示例 2：
输入：nums = [3,30,34,5,9]
输出："9534330"

示例 3：
输入：nums = [1]
输出："1"

示例 4：
输入：nums = [10]
输出："10"

提示：
1 <= nums.length <= 100
0 <= nums[i] <= 10^9

*/

class Solution {
public:
	string largestNumber(vector<int> &nums) {
		sort(nums.begin(), nums.end(), [](const int left, const int right) -> bool {
			string leftStr = to_string(left), rightStr = to_string(right);
			return leftStr + rightStr > rightStr + leftStr;
		});
		string res;
		for (auto n : nums) res += to_string(n);
		return res[0] == '0' ? "0" : res;
	}
};